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0 System and method for resource assignment and scheduling. 



^ 0 A system and method for assigning and scheduling resource requests to resource providers use a modified 

"best-first" search technique that combines optimization, artificial intelligence, and constraint-processing to arrive 
CO at near-optimal assignment and scheduling solutions. In response to changes in a dynamic resource environ- 
Irt ment, potential changes to an existing assignment set are evaluated in a search for a better solution. New calls 
m are assigned and scheduled as they are received, and the assignment set is readjusted as the field service 
CD environment changes, resulting in global optimization. Each search operation is in response to either an 
CO incremental change to the assignment set such as adding a nev/ resource request, removing a pending resource 
O request, reassigning a pending resource request, or to a request for further evaluation. Thus, the search 

technique assumes that the existing assignment set is already optimized, and limits the task only to evaluating 
Qj the effects of the Incremental change. In addition, each search operation produces a complete assignment and 

scheduling solution. Consequently, the search can be terminated to accept the best solution generated so far, 

making the technique an "anytime" search. 
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mem and scheduling solutions, while avoiding the combinatorial explosion inherent in existing optimization 
techniques. In particular, the present invention provides a system and method for assigning a plurality of 
resource requests among a plurality of resource providers, wherein the plurality of resource requests 
includes a plurality of pending resource requests assigned among the resource providers according to an 
existing assignment set, and wherein the existing assignment set defines a root node of a search tree. 
According to the system and method of the present invention, the root node is expanded by forming one or 
more next-level nodes, each of the next-level nodes corresponding to the root node but being further 
defined by a reassignment of one of the pending resource requests between one of the resource providers 
and another of the resource providers. A stress value is estimated for each of the next-level nodes, wherein 
the stress value represents a degree of undesirability of the respective reassignment, and a new 
assignment set is generated corresponding to one of the next-level nodes having a minimum stress value. 

It is to be understood that both the foregoing general description and the following detailed do^ription 
are exemplary and explanatory only, and not restrictive of the invention, as claimed. 

The accompanying drawings are included to provide a further understanding of the Invention and are 
incorporated in and constitute a part of this specification. The drawings illustrate exemplary embodiments of 
the invention and together with the description serve to explain the principles of the invention. 

Brief Description of the Drawings 

Fig. 1 is a functional block diagram of a computer-implemented software process structure incorporating 
a system for assigning and scheduling resource requests in accordance with the present invention; 
Fig. 2 is a functional block diagram of a system for assigning and scheduling resource requests in 
accordance with the present invention; 

Fig. 3 is a flow diagram illustrating a first mode of a system and method for assigning and scheduling 

resource requests in accordance with the present invention: and 

Fig. 4 is a search tree diagram illustrating the operation of the first mode shown in Fig, 3: 

Fig. 5 is a flow diagram illustrating a second mode of a system and method for assigning and scheduling 

resource requests in accordance with the present invention; 

Fig. 6 is a flow diagram illustrating a scheduling mode of a system and method for assigning and 
scheduling resource requests In accordance with the present invention; 

Fig. 7 is a scheduling diagram illustrating a lower bound calculation performed in the scheduling mode of 
a system and method for assigning and scheduling resource requests in accordance with the present 

invention; 

Fig. 8 is a search tree diagram illustrating a schedule sequence of resource requests for a particular 
resource provider in accordance with the present invention; 

Fig. 9 is a scheduling calendar illustrating the scheduling of resource requests in accordance with the 
present invention; and 

Fig. 10 is an example of a user interface displaying a set of schedules generated in accordance with the 
present invention. 

Detailed Description of the Prefenred Embodiments 

Reference will now be made in detail to exemplary embodiments of the invention. One skilled in the art. 
given the description herein, will recognize the utility of the system and method of the present invention in a 
variety of diverse resource environments in which assignment and scheduling problems exist. For example, 
it is conceivable that the system and method of the present invention may be adapted for assignment and 
scheduling problems existent in teiscommunications systems, transportation dispatching organizations, and 
emergency services dispatching oryanizations. However, for ease of description, as well as for purposes of 
illustration, the present invention will be descrikDed in the context of a field service environment. 

The system and method of the present invention will be described together herein, with the method 
contemplated as being implemented as a series of operations performed by the system. Fig. 1 is a 
functional block diagram of a computer-implemented software process structure 10 configured for applica- 
tion in a field sen^ice environment as described above. The software process structure 10 incorporates a 
system 12 for the assignment and scheduling of service calls in accordance with the present invention. 
Assignment/scheduling (A/S) system 12 is a software system realized, for example, by a software process 
running on a standard Unix^" workstation. The A/S system 12, which may t« implemented using the 
Common Lisp Object System (CLOS), is designed to run as a back-end processor for an existing SMS (not 
shown). The software process structure 10 further comprises an SMS interface 14 having an SMS access 
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The structure of A/S system 12 will now be described with reference to Rg. 2. The A/S system 12 
employs two software process modules that cooperate to reach an assignment set that optimizes a single 
objective function of the field service environment. As shown in Fig. 2. A/S system 12 comprises an 
assigner module 22 and a scheduler module 24. The assignor module 22 searches for potential assign- 

s ments of service calls among the service technicians, and evaluates a portion of the objective function 
relating to the desirability ol particular associations of calls and technicians. The assigner module 22 
invokes scheduler module 24 to search for the best schedule among a plurality of potential schedules of the 
calls assigned to a particular technician, and to evaluate a portion of the objective function relating to lime. 
Each of the potential schedules searched by scheduler module 24 represents a time-ordered sequence of 

10 the calls assigned to a technician. Thus, a complete assignment of a service call involves both an 
association of the call with a technician, as determined by assigner module 22, and a scheduling of the call 
at a particular time, as determined by the scheduler modulo 24. 

The A/S system 12 further includes throe main data structures 26. 28. 30, and a clock 32 accessed by 
assigner module 22. The assignment set data structure 26 stores a representation of the existing 

IS assignment set that defines an existing assignment of pending service calls among the service technicians. 
The assignment set data structure 26 also includes an existing schedule set that defines a schedule of the 
pending service calls assigned to each of the service technicians. The technician set data structure 28 
stores a representation of the existing technician set that defines the attributes of the technicians operating 
in the field service environment. The call set data structure 30 stores a representation of the existing call set 

20 that defines ttie attributes of the pending service calls. The clock 32 serves as a source of real-time for use 
in evaluating lime-related factors of an assignment. The assigner module 22 continuously updates the 
technician and call data structures 28. 30 to reflect changes in the field service environment as represented 
by the SMS and field events received by queue 20. The assigner module 22 also updates the assignment 
set stored In the assignn^ent set data structure 26 to represent assignment and scheduling recommenda- 

25 tions. 

As shown in Fig. 2, the scheduler module 24 accesses a calendar data structure 34 during the 
scheduling operation. The calendar data structure 34 stores a representation of the working calendar of the 
organization operating in the field service environment. The working calendar indicates time segments 
potentially available for the scheduling of service calls, and may be updated according to organizational 

30 calendar changes via user interfaces 18. Each of the time segments may correspond to the length of a work 
day. Thus, the scheduler module 24 accesses the calendar data structure 32 to determine which time 
segments are available work days, and to detemrtine scheduling boundaries between consecutive work days 
to avoid carrying calls over to the next day. 

The search operation of A/S system 12 will now be described. In response to an SMS or field event 

35 received at queue 20, the A/S system 12 conducts a modified "best-first" search that combines optimiz- 
ation, artificial intelligence, and constraint-processing techniques to arrive at near-optimal assignment and 
scheduling recommendations. When a change to the technician or call set is received, the A'S system 12 
executes a search that evaluates potential changes to the existing assignment set in an attempt to find a 
better distribution of calls among the technicians, as welt as a better scheduling of calls assigned to 

40 individual technicians. The A/S system 12 generates assignment and scheduling recommendations for all 
new calls as they are received, and immediately readjusts the assignment, resulting in global optimization. 
However, each search operation conducted by A/S system 12 explores the effects of only an Incremental 
change to the call set such as adding a new call, removing a pending call, or reassigning a pending call. 
Thus, the search technique assumes that the existing assignment set is already optimized, and limits the 

45 task only to minimizing the effects of the incremental change, thereby reducing the search space. The A/S 
system 12 also incorporates domain constraints into the search to further prune the search space. 

With each search operation, the A/S system 12 produces a complete solution for the field service 
environment, i.e.. all calls are assigned to technicians. Consequently, the search can be stopped at any 
time, taking the best solution found so far. This characteristic makes the search technique conducted by 

50 A/S system 12 an "anytime search." and enables the search to be suspended for other activity, but 
restarted later for improvements on the existing solution. For example, the A/S system 12 may search for 
better solutions In response to either a request for reevaluation by a system user, the passage of a 
predetermined amount of time, or simply the availability of Idle processing time. 

The SMS and field events received by queue 20 can be divided into the following three basic 

55 categories: a change to the call set. a change to the technician set. and a request for further evaluation. The 
response of the A/S system 12 to the three categories of events falls into two t>asic modes. The addition of 
a new service call initiates the first mode, called the new call event mode. The second mode is a general 
event mode initiated by all SMS and field events except the addition of a new service call. The new call 
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environment by the assignment of the new call, relative to the stress of the root node 72. Thus, the stress 
value of the root node 72 can be assumed to be zero. The incremental stress of the field service 
environment is merely the incremental stress to the particular technician affected by the assignment. 
Estimation of the stress value by the assignor nroduie 22 involves activation of the scheduler module 24 
5 and will be described in greater detail later in this specification. 

The assigner module 22 next sorts the first-level nodes 74. 76 by stress value, and adds them to a 
search queue for further expansion, as indicated by block 48. The first-level node having a minimum stress 
value is selected as the "least-stress* node, and is placed first in tfie search queue. The assigner module 
22 then calculates an initial stress threshold based on the minimum stress value, as indicated by block 50. 
10 The stress threshold constitutes the sum of the minimum stress value and a user-definable stress margin. 
This stress threshold is maintained throughout the search until a lower-stress node is generated, at which 
time the stress threshold is recalculated. The assigner module 22 selects the first node in the search queue 
for the next expansion, in accordance with the "best-first" characteristic of the search technique which 
dictates that least-stress nodes be explored first, and executes the next expansion by forming one or more 
IB of the next-level nodes 78-84 shown in search tree 70. 

Before further expansion, however, the assigner module 22 first determines whether certain search 
terminating conditions have been satisfied, as indicated by block 52 of Fig. 3. The assigner module 22 
expands the first node in the search queue only if the conditions are not satisfied. Although it is unlikely in 
the real world that the terminating conditions will occur at the first level (I) of the search tree, the assigner 
module 22 nevertheless checks the conditions at each level of the search. Specifically, the assigner module 
22 terminates the search If either the search queue is empty, the stress value of the first, least-stress node 
is greater than the prevailing stress threshold, the number of nodes generated is greater than a predeter- 
mined node count limit, or processing time has exceeded a predetenmined time limit. If any of the 
tenninating conditions is met. the assigner module 22 terminates the search and creates an assignment bet 
corresponding to the best node produced so far. as indicated by branch 54 and block 56 of Rg. 3. and 
returns the assignment set to a system user as a recommendation. 

In the exemplary search tree 70 of Fig. 4. it is clear that the search queue is not empty at the first level 
in view of the presence of first-level nodes 74 and 76. In fact, the occurrence of an empty search queue is a 
rare occurrence at any level in a real world field service environment because the boundaries of the 
techniaans' individual service territories typically overlap such that changes in the technician and call sets 
can in pnnciple propagate across the entire service territory. As the search progresses, however, there is a 
possibility that the number of potential next-level nodes may be exhausted, resulting in an empty search 
queue. Each of the next-level nodes 78-84 corresponds to the respective one of the first-level nodes 74 76 
from which it stems, but is further defined by a reassignment of one of the pending service calls between 
the selected one of the service technicians, i.e.. the servtee technician to whom the new service call was 
assigned in the first-level node, and another of the candidate service technicians. Thus, the empty search 
queue condition occurs only when next-level nodes have been formed for every possible combination of 
reassignments of the pending service calls between candidate technicians for the respective calls. 

Because the search technique is an "anytime" search, the assigner module 22 may terminate the 
search at any point beyond the root node 72. without affecting the completeness of the assignment and 
scheduling solution. This "anytime" feature enables the assigner module to apply the other terminating 
conditions shown in block 52 of Rg. 3. For example, the assigner module 22 expands the first node in the 
search queue only if it satisfies the prevailing stress threshold. At the first level of the search tree at least 
one node will satisfy the stress threshold. Specifically, the stress threshoW is equivalent to the stress value 
of the least-stress, first-level node plus the stress margin. Thus, the least-stress first-level node clearly will 
be less than the stress threshold. The stress value of the least-stress first-level node serves as a benchmark 
for the remaining nodes, thereby limiting the search space. The assigner module 22 does not even consider 
further expansion of first-level nodes that exceed the stress threshold. However, it is possible that first-level 
nodes that exceed the stress value of the least-stress node may later produce next-level nodes having 
lower stress values. Therefore, the value of the user-definable stress margin should be large enough to 
accommodate the "lumpiness" of the search space, as detemiined empirically by monitoring the actual 
field service envlronmem over lime, but small enough to avoid wasting time on unproductive expansions. 

The node count limit and time limit temrtinating conditions shown in block 52 provide maximum search 
constraints designed to further prune the search space. The node count limit specifies a maximum number 
of nodes that can be generated before the assigner module 22 terminates the search. The time limit defines 
a maximum elapsed processing time allotted for any single search. The node count limit and time limit 
conditions work particularly well in practice because the assigner module 22 tends to generate its least- 
stress nodes eariy in the search. The early generation of low-stress nodes resulte not only from the 
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The irvexpansion performed by assignor module 22 comprises the formation of one or more next-level 
nodes that correspond to the respective first-level node, but which are further defined by a reassignment of 
one of the pending service calls to the selected service technician, i.e., the technician to whom the new 
service call was assigned in the first-level node, from another of the service technicians. Thus, the selected 

5 technician qualifies as a candidate technician for the respective pending call. In-expansions are represented 
as cF -> T, where c is the pending call number, F is the technician from whom the pending call is 
reassigned, and T is the technician to whom the pending call is to be reassigned. 

Assuming that first-level node 74 is the first node in the search queue, examples of next-level nodes 
formed by in-expansion are next'level nodes 78 and 60. Next-level node 84 would represent an in- 

10 expansion of first-level node 76. provided first-level node 76 were the first node in the search queue. First- 
ievel node 74 is defined by the assignment of pending calls 1 and 2 to technician A. the assignment of new 
call 5 to technician 8, and the assignment of pending calls 3 and 4 to technician C. As in the out-expansion 
operation, in-expanston of first-level node 74 does not disturb the assignment of new call 5 to the selected 
technician B. Rather, in-expansion results in a next-level node 78 that corresponds to first-level node 74. but 

16 which is defined by a reassignment of pending call 1 from technician A to the selected technician B. As 
shown in Fig. 4, the expansion component 74b of first-level node 74 represents the above in-expansion as 
P: 1A-> B. 

The assignor module 22 repeatedly invokes the in-expanston operation one or more times to form in- 
expanded next-level nodes defined by each possible reassignment of pending calls to the selected 

20 technician, one call at a time. Similarly, the out-expansion operation is repeatedly invoked to form out- 
expanded next-level nodes defined by each possible reassignment of the pending service calls assigned to 
the selected technician. Of course, in each repetition, the reassignment must be directed to a candidate 
technician for the respective pending call. It is also noted that the assignor module 22 avoids generating the 
same expansions for a given technician more than once, and therefore does not repeat the reassignment of 

25 a pending call on any given path from the root node 72 of search tree 70. 

For each of the next-level nodes, the assignor module 22 estimates a stress value representing a 
degree of undesirability of the respective reassignment of the pending service call, as indicated by block 60 
of Fig. 3. The technique by which the assignor module 22 estimates the stress value for each of the next- 
level nodes is identical to that employed for the first-level nodes, requiring activation of the scheduler 

30 module 24. and. for this reason, will be described later in the specification. . As indicated by block 62. the 
assignor module 22 next updates the prevailing stress threshold by determining the minimum stress value 
of the stress values estimated for each of the next-level nodes. If one of the stress values is less than the 
minimum stress value determined for the first-level nodes, the assignor module 22 recalculates the stress 
threshold. For example, assuming that first-ievel node 74 previously was the least-stress node, but that 

35 next-level node 78 generated an even tower stress value, the assigner module 22 updates the stress 
threshold to reflect the stress value of next-level node 78 plus the user-defined stress margin. However, if 
none of the next-level nodes has a stress value less than that of the previous least-stress node, the stress 
threshold is unchanged. 

The assigner module 22 limits the depth of expansion by comparing the level of the new set of nexl- 
40 level nodes to a depth limit, as indicated by block 64, The depth limit specifies a maximum depth of the 
search tree 70. The assigner module 22 does not consider next-level nodes at the depth limit for further 
expansion, and does not add them to the search queue. Rather, if the level of the new set of next-level 
nodes is equal to the depth limit, the assigner module 22 carries out the next expansion cycle by expanding 
only the least-stress unexpended node already in the search queue, as indicated by loop 66. If the level of 
45 the new next-level nodes is less than the depth limit, however, the assigner module 22 sorts them by stress 
value and merges them into the search queue with the unexpended nodes, as indicated by block 68. Thus, 
new next-level nodes at a level less than the depth limit are considered for the next expansion, as indicated 
by loop 66. 

Before starting the next expansion cycle, the assigner module 22 first checks the terminating conditions 
50 of block 52. The first node in the search queue now represents the least-stress node of the remaining 
unexpanded first-level and next-level nodes. At this stage of the expansion, all next-level nodes are 
unexpended. With reference to Fig. 4. for example. If first-level node 74 was the previous least-stress node, 
and node 74 was expanded by fonming next-level nodes 78, 80. the nodes in the search queue would 
comprise unexpanded first-level node 76 and unexpanded next-level nodes 78 and 80. If the terminating 
55 conditions are not satisfied, the assigner module 22 starts the new expansion cycle. Specifically, as 
Indicated by block 58. the assigner module 22 removes the first node from the search queue and again 
executes the expansion operation by fonming one or more next-level nodes. 
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margin. Before executing an expansion cycle, the assigner module 22 checks the temnlnating conditions of 
block 118 which correspond to the terminating conditions applied in the new call event mode. The 
occurrence of one of the terminating conditions results In the termination of the search, as indicated by 
branch 120 and block 122. At the root level of the search tree, however, the terminating conditions of block 
s 118 will never be satisfied. 

The assigner module 22 next removes the root node from the search queue and expands it as a 
preceding-level node by forming one or more next-level nodes, as indicated by block 124 of Fig, 5. Each of 
the next-level nodes corresponds to the root node, but is further defined by a reassignment. Specifically, 
each of the nextHevel nodes is defined by the reassignment of one of the pending service calls between a 
w selected one of the service technicians and another of the service technicians. After the initial expansion of 
the root node for the selected technician, the assigner module 22 forms subsequent next-level nodes by 
propagating potential changes along the paths of the search tree, tf tho general event is a call attribute 
change, the selected technician is the technician to whom the changed call is assigned. The changed call 
may itself be reassigned to more appropriate technicians. If the general event is a technician attribute 

76 change, the selected technician is the technician having the changed attributes. If the general event is a 
request for further evaluation, the selected technician is either one of the technicians for whom the system 
user requested evaluation, or one of the technicians assigned a call for which the system user requested 
evaluation. If the general event is the passage of a predetermined amount of time, the selected technician is 
determined by the status of the pending calls assigned to the technician. This feature is designed to update 

20 the assignment set according to changes in the status of service calls over time, such as the completion of 
a call by a service technician, or to update out-of-date recommendations. The update principally involves 
operation of the scheduler module 24 to update the existing schedule set. Finally, if the general event 
involves the cancellation of a call, the selected technician is the technician to whom the cancelled call was 
previously assigned. In this manner, the assigner module 22 evaluates the reassignment of calls to and 

25 from the particular technician, in view of the modified assignment load of the technician. 

The next-level nodes result from either an in-expansion or an out-expansion of the root node, as 
described with respect to the new call event mode. Thus, the operation of the assigner module 22 in the 
general event mode basically corresponds to the portion of the new call event mode starting with the 
expansion of the first set of next-level nodes 78-84 shown in the search tree 70 of Fig, 4. After expanding 

30 the root node, the assigner module 22 estimates stress values for each of the resulting next-level nodes, 
representing a degree of undesirability of the reassignment of the respective sen/ice call, as Indicated by 
block 126 of Rg. 5. Again, estimation of the stress value requires the assigner module 22 to invoke the 
scheduler module 24. as will be discussed. The assigner module 22 then sorts the next-level nodes by 
stress value, and merges the next-level nodes into the search queue, placing the node having the minimum 

35 stress value first in the search queue. 

As in the new call event mode, the assigner module 22 determines whether the stress-threshold should 
be updated, If one of the stress values of the next-level nodes is less than the minimum stress value 
determined for the root node, the assigner module 22 recalculates the stress threshoW. The updated stress 
threshold then represents the sum of the minimum stress value of the next-level nodes and the stress 

40 margin. However, if none of the next-level nodes has a stress value less than that of the root node, the 
stress threshold Is unchanged. As indicated by block 130, the assigner modlule 22 nexts applies the depth 
limit to determine whether the new set of next-level nodes should be added to the search queue. If the new 
nodes satisfy the depth limit, the assigner module 22 sorts them by stress value, and merges them into the 
search queue, as indicated by block 134. The assigner module 22 otherwise begins the next expansion 

45 without the new nodes. As indicated by loop 132. the assigner module 22 then checks the terminating 
conditions shown in block 118 to determine whether a new expansion should be executed. If the terminating 
conditions are not met. the assigner module 22 begins a new expansion cycle by removing the first one of 
the unexpanded next-level nodes in the search queue, and expanding it to form one or more next-level 
nodes, as indicated by block 124. Thus, the first node in the search queue serves as a preceding-level node 

so for the generation of the next level of the search tree. As in the new call event mode, the assigner module 
22 conducts the stress estimation and stress threshold operations of blocks 126 and 128, respectively, and 
continues to generate new expansion cycles, according to the "best-first" search technique, by in- 
expansions and out-expansions until the terminating conditions of block 118 are met. The continued 
expansion results in a succession of next-level nodes. Upon occurrence of one of the terminating 

56 conditions, the assigner module 22 generates a new, recommended assignment set corresponding to the 
node having the minimum stress value. 

Estimation of the stress value by the assigner module 22 and scheduler module 24 in both the new call 
and general event nodes will now be described in detail. The primary goal of A/S system 12 is to minimize 
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of the service territory ot the technician to whom the call Is assigned, but high If the location falls outside of 
an acceptable travel time of the technician's territory. The assignor module 22 compares the service 
territory of the technician to the location associated with a call by reference to both the technician attributes 
stored in the technician set data structure 28 and the call attributes stored in the call set data structure 30. 
5 Incorporation of the territory stress value tv in the stress function reduces unnecessary travel time for the 
technicians. 

The skill stress value kv represents a number of skills, or resources, for which the technician to whom a 
call is assigned is qualified. The skills can be weighted to reflect relative values of individual skills such that 
the skill stress^ value kv represents a sum of the values. The purpose of the skill stress value kv is to retain 
70 the more broadly-trained technicians and technicians trained on higher-priority equipment "in reserve" if 
less broadly-trained technicians are available for the same service call. The assignor module 22 determines 
the skill stress value kv for a technician by reference to the technician attributes stored in the technician set 
data structure 28. 

The depth stress value dv represents the number of levels generated in the search tree. This value 
J5 penalizes prolonged searches, discouraging the continued search for nodes that produce only minimal 
improvements over nodes already obtained, and preventing excessive geographic spread. The assignor 
module 22 simply maintains a count of the number of levels generated in the search tree to determined the 
depth stress value dv. 

The schedule stress value si^ represents the degree of undesirability of the best schedule that can be 

20 generated for a particular technician. A schedule is a time-ordered sequence of the calls assigned to a 
technician. The "best" schedule is the particular sequence of calls producing the lowest schedule stress 
value. Estimation of the schedule stress value sv requires operation of the scheduler module 24. 

The assigner module 22 invokes the scheduler module 24 during the search when a call is added to a 
technician's schedule by assignment of a new call or reassignment of a pending call, a call is removed from 

25 a technician's schedule by reassignment, or a request for further evaluation Is received. Specifically, the 
assigner module 22 invokes the scheduler module 24 when the stress value of an assignment or 
reassignment is to be estimated, to thereby add the schedule stress value sv estimated by scheduler 
module 24 to the assignment stress calculation represented by equation (3). Each time the scheduler 
module 24 is invoked, the assigner module 22 passes a set of calls assigned to a technician who is affected 

so by a particular assignment or reassignment, or is the subject of a request for further evaluation. The 
assigner module 22 also passes a set of call attributes with the calls, a set of technician attributes for the 
technician to whom the call is assigned, and a current time as determined by reference to the clock 32. The 
scheduler module 24 uses the call attributes, technician attributes, and current time in the schedule stress 
calculation, as will be described. The scheduler module 24 responds to the assigner module 22 by 

35 generating a plurality of potential schedules of the calls assigned to the particular technician, and then 
estimates the schedule stress value of each of the potential schedules. The scheduler module 24 selects 
the potential schedule having the lowest schedule stress value as the "best" schedule. The lowest schedule 
stress value then serves as the schedule stress value sv in the assignment stress calculation (3). In 
addition, the assigner module 22 adds the "best* schedule to the schedule set defining the particular node 

40 under evaluation. 

The existing assignment set includes an existing schedule set that provides, for each of the technicians, 
an existing schedule of the pending calls assigned to the respective technician. As the search progresses, 
the assigner module 22 generates a schedule set for each of the first-level nodes and next-level nodes. 
Thus, the schedule set for each of the first-level nodes corresponds to the existing schedule set but 

45 includes a schedule of the new service call and the pending service calls assigned to the selected 
technician in the respective node. The schedule set for each of the next-level nodes con'esponds to the 
preceding-level node from which the respective node stems, but includes schedules of the pending service 
calls assigned and reassigned to each of the service technicians involved in the respective reassignment. 
When the search process is terminated, the assigner module 22 adds to the new, recommended schedule 

50 set the resultant schedule set tor the particular one of the nodes having the minimum assignment stress 
value. 

For each of the first-level nodes, for example, the scheduler module 24 effectively modifies the existing 
schedule set by the addition of a new schedule, which replaces a previous schedule. The scheduler module 
24 arrives at the new schedule by generating one or more potential schedules of the calls passed by 
55 assigner module 22 for the selected technician. The calls passed by assigner module 22 for a first-level 
node include the pending calls previously assigned to the selected technician and the new call added to the 
technician's schedule. The scheduler module 24 estimates a schedule stress value of each potential 
schedule to detemnine a relative degree of undesirability of the schedule. The scheduler module 24 then 
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commitment value Is included in the call attributes passed by asstgner module 22. 

(6) Xa is a tardiness value for the call of assignment a. The tardiness values Is 0 it the technician to 
whom the call is assigned is expected to arrive before a promised start time. Othen^se, the tardiness 
value represents a lime interval between the promised start time for the respective service call and an 

5 expected start time for the service call. The scheduler module 24 determines the tardiness value by 
comparing the scheduled time for a call with the promised start time. 

(7) is a multiplier for the tardiness value of uncommitted calls set by the field service organization. 

(8) wc is a muitiptier for the tardiness value of committed calls set by the field service organization. 

(9) Be is the travel time value representing a tirne required by the technician to whom the respective 
10 service call of assignment a is assigned to travel to a location associated with the call from a preceding 

location. The scheduler module 24 may determine the travel time by reference to a travel time file listing 
estimated times for travel between specific locations. Atternativelyt the scheduler module 22 may refer to 
postal zip codes for the locations associated with each call, as indicated in the call attributes, and 
calculate the travel time based on the distance between the centroids of the zip codes. 
75 (10) €.»« is a multiplier for the travel time value set by the field service organization. 

The technique by which the scheduler module 24 generates potential schedules will now be described 
in greater detail. Because the scheduler module 24 is repeatedly invoked by the assignor module 22 to 
evaluate assignments, its performance is one of the principle factors in the performance of the entire A/S 
system 12. Therefore, the amount of processing required for each scheduling operation should be kept to a 
20 minimum. In the absence of processing constraints, however, the potential schedules generated by 
scheduler module 24 could include an extremely high number of possible call sequences for a particular 
technician. For n number of calls assigned to the technician, the scheduler module 24 could generate n\ 
different potential schedules in some cases. To reduce this combinatorial complexity, the scheduler module 
24 employs a combination of pruning techniques to reduce the amount of processing required for each 
25 scheduling operation. Specifically, the scheduler module 24 employs a pair of pruning heuristics designed 
to completely avoid the necessity of a full-scale scheduling operation, and a third pruning heuristic 
designed to reduce the number of potential schedules generated during a scheduling operation. Thus, the 
scheduler module 24 generates an original potential schedule only as a last resort after application of the 
pruning heuristics. 

30 The first and second pruning heuristics will be described with reference to Figs. 6 and 7. The first 
pruning heuristic is herein referred to as "caching," whereby the scheduler module 24 avoids the redundant 
generation of potential schedules that have already been generated. In response to the addition of a call, 
the removal of a call, or a request for reevaluation. as indicated by block 140 in the flow diagram of Fig. 6, 
the scheduler module 24 must generate a least-stress schedule of the set of calls passed by assignor 

3S module 22 for a particular technician. Before generating any potential schedules, however, the scheduler 
module 24 searches a plurality of schedules stored, or "cached." in a schedule buffer associated with the 
scheduler module 24, The schedules stored in the schedule buffer represent "best" schedules generated in 
previous runs of the scheduler module 24. The schedule buffer stores each schedule with its corresponding 
schedule stress value, as detenmined previously by the scheduler module 24. The scheduler module 24 

40 maintains the contents of the schedule buffer for a predetermined amount of time for future reference. The 
scheduler module 24 accesses the schedule buffer in an attempt to find a "non-obsolete," matching 
schedule previously generated for the same set of calls and the same technician passed by the asstgner 
module 22. as indicated by block 142. A schedule is "non-obsolete" if a better schedule has not been 
generated in a subsequent run of the scheduler module 24, and if a significant amount of time has not 

45 passed. The matching schedule represents a time-ordered sequence for an identical assignment of calls to 
the same technician under evaluation. If a matching schedule Is kxated, the scheduler module 24 simply 
selects that schedule as the best schedule for the particular technician and returns it to the assignor module 
22 with the con^esponding schedule stress value, as indicated by branch 144 and block 146. Thus, the 
caching technique avoids performing the same scheduling work more than once. 

50 If the scheduler module 24 does not locate a matching schedule in the schedule buffer, the scheduling 
operation advances to the second pruning heuristic. The second pruning heuristic Involves the calculation of 
a lower bound for the addition of a new call or a pending call to an original schedule having one or more 
calls. As indicated by block 14S of Rg. 6. the scheduler module 24 uses the lower bound to prune the 
schedules that are too expensive. Specifically, if the addition of the call produces a stress value that is 

55 greater than the lower bound, the particular node is deemed too expensive, and the scheduler module 24 
notifies the assignor module 22 that the node should be discarded without further evaluation. The scheduler 
module 24 notifies the assignor module 22 by returning an indication that the scheduler module 24 failed to 
generate a schedule within acceptable stress limits, as indicated by branch 150 and block 154. 
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If the lower bound y is not less than the worst acceptaDle schedule stress value i^,, the scheduler module 
24 indicates to the assigner module 22 that the node is to be discarded. If the lower bound Is satisfied, 
however, the scheduler module 24 advances to the next stage in the scheduling operation. 

If the caching technique does not produce a matching schedule, and the tower bound test Is satisfied, 
the scheduler module 24 must produce a minimum stress schedule for the set of calls passed by the 
assigner module 22. as indicated by block 148 of Fig. 8. At this stage, however, the scheduler module 24 
applies a third pruning heuristic to reduce the factorial complexity of the scheduling possibilities. Specifi- 
cally, the scheduler module 24 employs a recursive "depth-first" schedule search technique in which one or 
more of the calls are prioritized as critical calls at each level of recursion. The scheduler module 24 
recursively builds a sequence of the calls one-call-at-a-time, but prunes the number of possitDilities at each 
level of recursion by considering placement of only the critical calls next in the schedule sequence. The 
pruning operation thereby eliminates the need to evaluate the placement of non-critical calls next in the 
sequence. 

One example of a aitical call Is a committed call, where an arrival time has been promised to the 
customer. Because the committed call should not be scheduled later than the promised arrival time, it is 
designated a critical call that must be considered for placement next in the schedule sequence. Thus, 
initially the scheduler module 24 determines whether a call a is critical based on the definition 

critical = {a:ahasC = 1} (11) 

where C = 1 indicates that the call a has been committed. The critical status of a committed call is 
maintained throughout the recursion by scheduler module 24. 

If the definition yields critical - 0, however, the scheduler module 24 determines whether calls are 
critical based on their travel times $n from the particular technician's starting location and tardiness Xn, as 
well as by their priorities P„. At the root of each recursion, the technician's starting location is the 
technician's current location. As the recursion progresses to buikJ a schedule sequence, however, the 
starting location is the location associated with the immediately preceding call in the sequence. This change 
In the starting location requires the recalculation of criticai at each level of the recursion. Consequently, the 
calls designated as critical will change as the recursion progresses. 

Each call is evaluated for criticai based on the following tests: 

(A) Location: Is the travel time less than or equal to the average travel time for this set of calls, 

nax(*J + inin(fl,) 
«. ^ ? 

2 

(B) Tardiness: Is tardiness greater than or equal to the average tardiness for this set of calls, 

inax(Xj + inin(X,) 

X. ^ ? 

2 

(C) Priority: Is this a priority call, 

Pa> 0? 

The scheduler module 24 creates the following partitions based on tests (A>-(C): 
as: This partition contains the calls meeting all three tests (A)-(C): 

02: If the number of calls in 03 ^ 1/2 of the number of calls in this schedule, a? - 0; else, 02 contains 
all calls that meet any two of tests (A)-(C); and 

ai: If the number of calls in 03 + 02 1/2 of the numt)er of calls in this schedule, 01 = else 
ai contains all calls that meet any of tests (A)-(C). 

The set of critica\ calls is thus: critical = {aa u 02 U o /}. The union ensures that a sufficient number of 
calls will t>e designated as critical calls at each stage of the recursion, while the partitions ensure that the 
numt>er of critical calls is minimized. 
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time btocks specified by the technician calendar stored In the technician attributes passed by assignor 
nnoduie 22. The available time segments generally will correspond to a maximum of an entire work day, 
which may run, for example, from 8:00 to 17:00. The technician's calendar tracks appointments and other 
times unavailable for the scheduling of calls as fixed blocks of time at points during the lime segment 

5 specified by the organizational calendar. The unavailable times are associated with locations that are used 
to calculate travel time between the appointment and service calls. The available time segments are hashed 
into time bins, with the beginning of each bin being either the start of the day. or the end of the previously 
scheduled call or unavailable time. The end of a time bin is then either the end of the same day. or the start 
of either the next scheduled call or an unavailable time. The scheduler module 24 caches the set of time 

10 bins for each technician to avoid regeneration at each level of the schedule search recursion. 

Fig. 9 is an example of a technician's schedule divided Into time segments and time bins. Each of the 
time segments 200, 202. 204 corresponds to an entire work day. Tuesday, Wednesday, Thursday, 
respectively. The first time segment 200, Tuesday, includes an unavailable block of time 206 from 08:00 to 
14:00, and an available time bin 208 beginning at the end of block 206, plus travel time 212. Thus, the 

15 scheduler module 24 also considers travel times 210. 212. and 214 as part of the time segment 20o/The 
time bin 208 ends at 17:00, the end of the time segment, minus the travel time 214. The Wednesday time 
segment 202 does not include any unavailable block of time, and therefore consists of a single time bin 218 
spanning the entire work day, but bordered by travel times 218. 220. In contrast, the Thursday time 
segment 204 is hashed into two time bins 222. 224. The first time bin 222 begins at the beginning of the 

20 work day. 8:00. plus travel time 226. and ends at the beginning of an unavailable block of time 228. minus 
travel time 230. The second time bin 224 begins at the end of block 228, plus travel time 232. and runs 
through the end of the work day, 17:00, minus travel time 234. 

When the scheduler module 24 selects a call to be next in the sequence of a potential schedule, it 
determines a start time for the call based on the following factors: 

25 (1) a travel time en->m between locations associated with a preceding call n and the next call m to be 
scheduled, or between locations associated with the next call m and either a preceding block of 
unavailable time or the beginning of the time segment: 

(2) a duration of the next call /n to be scheduled based on an expected repair time of the machine 
associated with the call m; and 
30 (3) a length ibin of the time bin in which the next call m is to be scheduled- 

Thus. to ensure that the duration of the next call m fits within the time bin. indicating available 
scheduling time, the scheduler module 24 schedules call m next in the sequence only if: 

35 

Where ec->7 represents the travel time between locations associated with the call m to be scheduled and the 
next call to be scheduled after call m. 

Fig. 10 is an example of a graphical representation of a portion of the assignment set and schedule set 
generated by A/S system 12. as displayed to the system user by user interface 18. The user interface 18 

40 preferably displays an interactive scheduler window 240 containing a representation of the calls assigned to 
each technician and the times at which the calls are scheduled. The scheduler window 240 includes a 
technician field 242 containing a representation of a particular group of technicians under evaluation by the 
system user, a schedule field 244 containing a representation of the calls assigned to each of the 
technicians and the particular times for which the calls are scheduled, and a command bar 246 containing 

45 representations of standard window control commands. 

M Fig. 10. the technician field 242 displays a group of technicians A. B, C, D, and E operating in the 
field service environment The schedule field 244 represents the exisUng schedules of the technicians, as 
generated by the scheduler module 24. subject to approval or modification by the system user. The 
schedule field 244 in Fig. 11 indicates that technician A has been assigned first, second and third 

50 scheduled calls represented by call blocks 248, 250, and 252. which define assignments. The call blocks 
248, 250. 252 represent scheduling of the calls between 9:00 and 15:00 in a time segment corresponding to 
Monday. May 17. Specifically, call blocks 248. 250. and 252 indicate assigned start times for the first, 
second, and third calls of approximately 9K)0. 11:15. and 1:15. respectively. The completion times indicated 
by call blocks 248, 250. 252. respectively, are approximately 10:45. 12:45, and 2:45. 

55 The schedule field 244 also includes time blocks 254, 256, 258 representing travel times. Time block 
254 indicates the initial travel time, from the beginning of the day. required for the technician to travel from 
the starting location, or from a locaUon associated with an otherwise unavailable time, to the customer 
location associated with the first call. Time blocks 256 and 258 represent the travel times that separate the 
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4. The method according to claim 3. characterized in that said existing assignment set includes an 
existing schedule set, said existing schedule set Including, tor each of said resource providers, an 
existing schedule of the pending resource requests assigned to the respective resource provider, said 
method further comprising the steps of: 
5 generating, for each of said first-level nodes, a schedule set corresponding to said existing 

schedule set but including a schedule of said new resource request and the pending resource requests 
assigned to said selected one of said resource providers, and 

generating, for each of said next-level nodes, a schedule set corresponding to the schedule set for 
the respective preceding-level node but including schedules of the resource requests assigned and 
70 reassigned to said one and said another of said resource providers, 

wherein said new assignment set includes the schedule set for the respective one of said first-level 
nodes and said next-level nodes having said minimum stress value. 

& The method according to claim 4. characterized In that said step of generating a schedule set for each 
75 of said first-level nodes includes the steps of: 

generating one or more potential schedules of said new resource request and the pending resource 
requests assigned to said selected one of said resource providers, estimating, for each of said 
potential schedules, a schedule stress value representing a degree of undesirability of the respective 
potential schedule, and 

20 selecting one of said potential schedules having a minimum schedule stress value as said schedule 

for said selected one of said resource providers. 

6. The method according to claim 5. characterized in that said step of generating a schedule set for each 
of said next-level nodes includes the steps of: 
25 generating one or more potential schedules, said potential schedules including one or more first 

potential schedules of the resource requests assigned to said one of said resource providers, and one 
or more second potential schedules of the resource requests assigned to said another of said resource 
providers. 

estimating, for each of said potential schedules, a schedule stress value representing a degree of 
30 undesirability of the respective potential schedule, and 

selecting one of said first potential schedules having a first minimum schedule stress value as said 
schedule for said one of said resource providers, and one of said second potential schedules having a 
second minimum schedule stress value as said schedule for said another of said resource providers. 

35 7. The method according to claim 6, characterized in that, in said step (a}(ii), the stress value estimated 
for each of said first-level nodes includes a representation of said minimum schedule stress value for 
the respective first-level node, and. in said steps (b) and (f). the stress value estimated for each of said 
next-level nodes includes a representation of said first minimum schedule stress value and said second 
minimum schedule stress value for the respective next-level node. 

40 

8. The method according to any one of claims 5 to 7, characterized in that said step of generating said 
one or more potential schedules for each of said first-level nodes includes, before generating said 
potential schedules, the steps of: 

estimating a worst acceptable schedule stress value, 
45 estimating, for each of said first-level nodes, a minimum stress of insertion of said new resource 

request among the pending resource requests on the existing schedule for said selected technician, 
and 

discarding each of said first-level nodes having a minimum stress of insertion that exceeds said 
worst accept^le schedule stress value. 

50 

9. The method according to claim 6 or 7, characterized in that said step of generating said one or more 
first and second potential schedules for each of said next-level nodes includes, before generating said 
potential schedules, the steps of: 

estimating a worst acceptable schedule stress value. 
55 estimating, for each of said next-level nodes, a minimum stress of insertion of the pending resource 

request reassigned to one of said one and said another of said resource providers among the pending 
resource requests on the existing schedules for the respective one of said one and said anotiier of said 
resource providers, and 
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